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Abstract (Basic) : EP 540095 A 

The microcircuit is used in a multi-application smart card having a 
read-only memory (12), a programmable memory (13) and a circuit 
controlling addressing of the programmable memory. 

The programmable memory is divided into two zones: an index zone 
and an application zone. The index zone holds for each application a 
reference code and the addresses of the start and finish of the space 
allocated to each application. The microcircuit can also inhibit all 
commands to the programmable memory when it is associated with an 
address outside the address range of the application, unless it is from 
a priority operation held in ROM. 

ADVANTAGE - Prevents illicit writing to blank smart cards. 

Dwg.1/3 

Abstract (Equivalent) : EP 540095 B 

The microcircuit is used in a multi-application smart card having a 
read-only memory (12), a programmable memory (13) and a circuit 
controlling addressing of the programmable memory. 

The programmable memory is divided into two zones: an index zone 
and an application zone. The index zone holds for each application a 
reference code and the addresses of the start and finish of the space 
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allocated to each application. The microcircuit can also inhibit all 
commands to the programmable memory when it is associated with an 
address outside the address range of the application, unless it is from 
a priority operation held in ROM. 

ADVANTAGE - Prevents illicit writing to blank smart cards. 

Dwg. 1/3 

Abstract (Equivalent): US 5452431 A 

A microcircuit for a chip card, comprising: 

(a) a processor for accessing a memory address space; 

(b) a read-only memory in the memory address space and which 
contains functional routines that are exclusively accessible to the 
processor; 

(c) a programmable memory in the memory address space comprising a 
repertory region and an application region which are distinct from one 
another, the application region being allocable into separate and 
distinct application sub-regions, each sub-region being allocable for 
accommodating storage of one of a plurality of independent application 
programs, each of said application sub-regions when loaded with an 
application program comprising an address space defined by contiguous 
addresses between unique upper and lower limit address values, the 
repertory region accommodating storage containing, for each application 
program stored in a respective application sub-region, a respective 
reference code and respective upper and lower limit address values of 
contiguous addresses of an application sub-region exclusively allocated 
to an application program; 

(d) lockable means for storing upper and lower limit address 
values; 

(e) the functional routines in said read-only memory comprising, 
under the control of the processor, a first routine for loading an 
application program into an application sub-region including allocating 
address space needed by the application program and storing upper and 
lower limit address values of said allocated address space in the 
repertory region, and a second routine for obtaining from the repertory 
region and loading in the lockable means upper and lower limit address 
values of a particular application program in response to a call from 
the processor to run the particular application program; 

(f) control means for controlling access to the programmable memory 
including: 

(i) means for making a comparison between an address requested by a 
running application program and upper and lower limit address values 
stored in the lockable means by said second routine from the repertory 
region and corresponding to the running application program; 

(ii) means in response to the requested address lying inside the 
upper and lower limit address values in the lockable means for granting 
memory access to the requested address and in response to the requested 
address lying outside the upper and lower limit address values for 
denying memory access; 

(iii) in response to a command to run a designated application 
program, a priority authorization channel for temporarily unlocking 
said lockable means and for storing therein the upper and lower limit 
address values of the designated application program when the second 
routine is executed and for restoring a locked condition to the 
lockable means while the designated application program is running; 

(g) the processor comprising an instruction counter, .and the 
priority authorization channel comprising a flip-flop connected to 
receive a reset command from the processor when the processor is 
initialized, and to receive a set command in response to an address 
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value contained in the instruction counter when said address value 
designates an address in the address space of the programmable memory, 
said flip-flop being operative to supply a locking/unlocking signal for 
controlling the locking of the lockable means and for controlling the 
priority authorization channel. 
Dwg.1/3 
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© Mlcrocircuit pour carte a puce a mtfmolre programmable protegee. 



© Microcircuit pour carte a puce multi - applica - 
tions comportant notamment une m6moire ROM 
(12), une mgmoire programmable (13) et un circuit 
de contrdle d'adressage (14) de cette moire 
programmable. 

Selon Tinvention, la mSmoire programmable (13) 
est partag£e en au moins une zone de repertoire 
(ZR) et une zone des applications (ZA), la zone de 
repertoire (ZR) comportant par application chargde, 
au moins un code de reference d*une application i 
prgsente dans la zone ZAj ainsi que les adresses 
ZA|| et ZA)h respectivement de d£but et de fin de la 
zone ZA| allou£e a cette application. 

Le microcircuit comporte £galement des moyens 
(25 a 50) pour inhiber toute commando (R, WouE) 
de la m£moire programmable (13) lorsqu'elle est 
relative a une adresse exterieure a I'intervalle ZA,, - 
ZA] h de 1'application en cours de traitement et sauf 
s'il s'agit d'une operation prioritaire sp6cifiquement 
prSvue par un programme fixe" dans la m£moire 
ROM (12). 

Application : carte a microcircuits. 
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La presents invention concerne un microcircuit 
pour carte k puce comprenant entre-autres : des 
moyens d'acces entree - sortie, au moins une 
mdmoire qui est programmable et accessible par 
un espace d'adressage k adresses cons£cutives, 
un circuit de contr6le d'adressage de cette my- 
moire programmable determinant sort une inhibi - 
tion, soit une validation des commandos d^criture 
et/ou de lecture par la comparaison de I'adresse 
demand^e avec deux valeurs limites de ctebut et 
de fin d'une zone particuliere d'adresses, limites 
qui sont m^moris^es au sein du circuit de contrdle 
d'adressage lequel circuit comporte £galement une 
voie d'autorisation prioritaire permettant de s'af- 
franchir temporairement de ladite inhibition dans 
des circonstances preterm in^es et particulieres. 

Un tel microcircuit est notamment connu du 
document FR 2 304 989. 

(.'application dans le domaine bancaire des 
cartes portatives au sein desquelles est incorpord 
un circuit intggre* yiectronique (encore appeie 
"puce") est bien connue ainsi que la grande se* - 
curite* de fonctionnement qui en re*sulte. II est en 
effet pratiquement impossible d'acc^der k certai - 
nes donn€es inscrites dans des zones prot£g£es 
du microcircuit sans le d£truire. Par ailleurs, lors de 
I'utilisation, un protocole d'identification faisant in - 
tervenir un code personnel et secret, inscrit dans 
une zone prot£g6e du microcircuit, permet d'in- 
terdire toute tentative d'usage de la carte si les 
conditions d'identification ne sont pas satisfaites. 

Dans le cas d'une carte bancaire, le fabricant 
de carte cre*e dans un premier temps des cartes 
dont le microcircuit est vierge de toute information 
personna!is£e, puis dans un deuxieme temps, il y 
inscrit, par programmation des donnSes secretes, 
personnalisant chaque carte. Les cartes sont en- 
suite prot6ge*es par des verrous technologiques 
irrgversibles. 

Les codes personnels d'identification sont alors 
envoySs k chaque utilisateur (clients de la ban- 
que), et, par une autre route, les cartes elles- 
m§mes sont exp£di6es k la banque, ou les clients 
sont pri^s de venir les retirer. Ce systeme se 
r^vele d'une grande se*curit§ contre les tentatives 
d'usurpation. 

Bien entendu, une carte k puce est susceptible 
de servir k bien d'autres applications, en dehors du 
domaine bancaire, ou ('aspect pratique de porta- 
bility de la carte et de sa security d'utilisation 
offrent des perspectives interessantes. 

On peut penser k developper un microcircuit 
sp^cifique de chaque cas duplication particulier 
envisage mais il est plus economique et plus sim - 
pie de preVoir des microcircuits d'un type suffi- 
samment universel pour que Tune ou I'autre des 
applications envisaged y sort ensuite programm^e. 



Dans cette perspective, des problemes appa- 
raissent d6j& du point de vue de la s£curit£ si on 
envisage de confier k une entite autre que le 
fabricant de microcircuit, le soin d'inscrire les 

s donn£es secretes d'identification et les donn£es 
fonctionnelles de sa propre application. 

En effet une personne mal intentionn^e ayant 
r£ussi k se procurer des cartes vierges et ayant 
par ailleurs pris connaissance des techniques 

w description d'une certaine application, serait sus - 
ceptible de reciter ilticrtement des cartes falsifies 
en utilisant une technique description de donn£es 
qui imite I'originale. 

Or, Pentite* emettrice de ('application, qui est 

75 etrangere au fabricant de microcircuit, peut d£sirer 
charger elle-meme les donnees de son applica- 
tion, entre-autres pour ne pas livrer ses secrets 
au fabricant de microcircuits. 

Ces difficultes relatives k la s^curite* sont en - 

20 core aggrav£es dans le cas ou on envisage de 
crder des cartes dites "multi- application" d'un 
type universel, vierges k I'origine, et qui sont aptes 
k etre ch argues successivement et dans un ordre 
de succession quelconque, de donnees et pro- 

25 grammes d'applications diff^rents les uns des au - 
tres, par des entit£s emettrices qui sont etrangeres 
les unes aux autres. Le but recherche sera alors 
d'effectuer une allocation dynamique de la me"- 
moire programmable dans des conditions de s6 - 

30 currte* satisfaisantes. 

Le fabricant de microcircuits devrait pouvoir 
assurer une possibility de protection de plusieurs 
zones de me* moire dont il ne connatt pas encore 
les limites individuelles, de maniere que chaque 

35 entity emettrice puisse protSger la zone ou elle a 
charge ses donnees fonctionnelles secretes, contre 
toute tentative de lecture ou d'ecriture provenant 
du deVoulement d'une autre application, que ces 
tentatives proviennent d'une erreur de program - 

40 mation de I'entite ayant emis cette autre application 
ou qu'elles proviennent de la programmation illicite 
d'un fraudeur.On doit se rendre compte qu'il serait 
illusoire de confier k une plurality d'entitds sus- 
ceptibles de charger diverses applications, des 

45 secrets de programmation relatifs au chargement 
des applications en esperant que ces secrets ne 
parviennent jamais dans les mains de personnes 
mal intentionnyes. Une solution ne peut §tre envi - 
sagye dans cette direction d'autant plus qu'une 

so entity bien qu'autorisee mais maladroite peut 
ymettre une application contenant une erreur de 
programmation aboutissant k la destruction d'une 
donnee contenue dans une application etrangere k 
la sienne. 

55 L'invention vise tout particulierement le cas 
d'un microcircuit pour carte k puce du type multi - 
applications, dans lequel un haut niveau de se- 
curity est maintenu malgry que la carte soit fabri - 
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qu6e dans un 6tant vierge et qu'elle soit suscepti - 
ble d'dtre charge, dans un ordre indifferent, par 
des entitSs emettrices d'applications qui sont in- 
dependantes les unes des autres. En quelque 
sorte, le microcircuit souhaite devrait disposer de 
verrous mobiles mais inviolabtes que ce soit en 
cours de chargement. de fonctionnement, ou par 
renvoi de signaux quelconques sur les accfes 
d'entree- sortie. 

^invention a pour but de foumir une solution a 
ce probleme technique. 

En effet, selon I'invention, un microcircuit pour 
carte a puce, d'un type conforme au paragraphe 
introductif, est caracterise en ce que, en vue d'un 
chargement et d'une exploitation de programmes 
d'applications ind£pendants les uns des autres, le 
microcircuit est muni d'une unite centrale de mi - 
croprocesseur, d'une memoire a lecture seule 
(ROM) contenant notamment des routines fonc- 
tionnelles exclusivement ex^cutables par Punite 
centrale et sous sa d£pendance, en ce que dans 
I'espace d'adressage de la memoire programmable 
sont d£iimit£es une zone dite de repertoire et une 
zone dite des applications, lesquelles zones sont 
exclusives Tune de I'autre, en ce que la zone de 
repertoire contient une table repertoire ou les 
adresses de debut et de fin ainsi qu'un code de 
reference de chacun des programmes d'applica- 
tions susceptible d'etre charge dans une portion de 
la zone des applications, sont inscrits au fur et a 
mesure du chargement desdits programmes et en 
utilisant une desdites routines fonctionnelles, en ce 
que le circuit de controls d'adressage est agence 
pour inhiber les commandes d'ecriture et de lec - 
ture de la memoirs programmable pour des 
adresses qui se situent a I'exterieur de I'intervatle 
dettni par les valeurs limites de debut et de fin 
d'une application designee preaiablement sur les 
acc&s d'entree - sortie, limites qui sont memorisees 
dans des registres verrouillables, appeies registres 
de limites tandis que la voie dite d'autorisation 
prioritaire comporte des moyens pour s'affranchir 
de I'inhibition pr6citee en autorisant recriture et la 
lecture de la zone de repertoire a la condition 
exclusive que ces operations soient effectuees au 
moyen d'une desdites routines fonctionnelles du - 
rant une etape operatotre predeterminee durant 
laquelle les registres contenant les valeurs limites 
sont deverrouilies. 

Ainsi, dans le cas general ou un programme 
d'application est d6ja charge dans la carte et ap - 
peie par I'intermediaire les moyens d'accfcs 
entree - sortie, un protocole standard de recon- 
naissance de P utilisation pr6vu parmi les routines 
fonctionnelles est execute. Apres quoi, une autre 
routine commando une recherche dans la table 
repertoire, les valeurs limites d'adresse corres- 
pondent au programme d'application demande, 



identifie dans ladite table par son code de refe- 
rence, et ces valeurs sont chargees dans les re- 
gistres de limites, deverrouilies durant cette etape 
initiate de fonctionnement. 

5 Le programme d'application demande est en - 

suite lance et simultanement, les registres de li- 
mites sont verrouilies de sorte que les demandes 
d'acces en ecriture ou en lecture qui designeraient 
la memoire programmable en dehors de la zone 

10 d'adresses comprise entre les valeurs limites me - 
morisees, resteront sans effet, par exempte jusqu'a 
ce que le microcircuit soit mis hors tension. La voie 
d'autorisation prioritaire est en effet refermee. De 
cette maniere, un programme d'application est seul 

75 a pouvoir lire ou ecrtre dans la zone d'adresse qui 
lui est affectee et qui a ete fixee lors du charge - 
ment. Les autres programmes d'applications sont 
proteges contre toute tentative de lecture ou 
d'ecriture. 

20 En ce qui concerne le chargement de tout 
nouveau programme d'applications au sein de la 
carte, la securite provenant de Pabsence d'interfe - 
rence avec d'autres zones de la memoire pro- 
grammable est assume par des moyens similaires. 

25 Toute demande de chargement d'un pro- 
gramme d'application sur les moyens d'acces 
entree -sortie fait I'objet d'un protocole standard 
engage en liaison avec une routine fonctionnelle 
specialisee contenue dans la memoire a lecture 

30 seule. Le code de reference de I'application ainsi 
que I'espace memoire requis doivent etre annon - 
ces durant ce protocole. Une routine fonctionnelle 
specifique a pour effet de rechercher dans la table 
repertoire quelle est la premiere adresse disponible 

as dans la zone! des applications (Padresse qui suit 
Padresse de fin la plus e levee des programmes 
d'applications deja charges ou la premiere adresse 
de la zone des applications lorsque la carte est 
vierge). L'adresse de fin de I'application demandee 

40 est caJcuiee a partir de la demande d'espace me - 
moire annoncee precedemment. Lorsque cette 
adresse de fin d'application est compatible avec 
I'espace memoire de la zone des applications, les 
valeurs limites d'adresses de debut et de fin ainsi 

45 que le code de reference de I'application sont alors 
inscrits dans la table repertoire et ces valeurs li - 
mites sont chargees dans les registres de limites, 
toujours par le moyen d'une routine fonctionnelle 
preetablie et intangible. 

so Durant ces etapes qui precedent le charge- 
ment, les registres de limites sont deverrouilies, et 
ils peuvent le rester durant le chargement du pro- 
gramme d'application qui s'ensuit. La securite re - 
cherch6e est neanmoins conservee par le fait que 

55 le chargement du programme d'application est ef - 
fectue sous le contrdle de Punite centrale et par 
I'effet d'une routine fonctionnelle preetablie et sOre 
qui exclut toute modification de contenu des re- 
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gistres do Iimites. 

On peut aussi pr^voir un verrouillage de ces 
registres qui soit command^ par programmation 
juste avant le chargement. 

Toute tentative de chargement en dehors des 
iimites d'adresses etablies pr^c^demment restera 
sans effet. L'opdration de chargement peut etre 
compietee, si on le juge necessaire, par une routi - 
ne de verification des donn£es charg^es, une v6 - 
rification de signature, un test de parit6...etc... mais 
de telles operations n'auront pas pour effet d'ac- 
croftre de manure significative la s£curit6 de 
fonctionnement du microcircuit selon I'invention. 

La voie d'autorisation prioritaire peut etre 
commandee de difterentes manures en appliquant 
des conditions logiques appropri^es et en fonction 
du deroulement des Stapes op^ratoires qui suivent 
la mise sous tension du microcircuit. 

Toutefois, selon un mode de mise en oeuvre 
pn3f6r6 de I'invention, qui offre toute garantie du 
point de vue de la s£curit£, le microcircuit se 
caracterise en ce qu'il comporte une bascule bis - 
table, plac£e dans un premier etat exclusivement 
lors d'une mise sous tension du microcircuit, puis 
plac£e dans un deuxfeme etat oppose au premier, 
des qu'un compteur ordinal associe a I'unite cen - 
trale, contient une valeur d'adresse comprise dans 
I'espace d'adressage de la memoire programma- 
ble, et en ce que cette bascule bistable deiivre un 
signal de verrouillage/deverrouillage pour la com - 
mande de verrouillage des registres de Iimites et 
pour la commando de la voie d'autorisation priori- 
taire. 

Du fait qu'il est lie au compteur ordinal, le 
signal de verrouillage/deverrouillage fournit un 
moyen inviolable par un programme d'application 
quelconque pour le verrouillage des registres de 
Iimites et de la voie d'autorisation prioritaire, bien 
que la bascule bistable reste par sa nature un 
element reversible dans le temps. 

Com me les routines fonctionnelles qui ont pour 
objet de lire et/ou ecrire dans la table repertoire 
sont inscrites dans la memoire a lecture seule, le 
compteur ordinal pointe cette memoire pour les 
executer pas h pas. 

II suffit done de placer I'execution de ces rou - 
tines dans des etapes operatoires qui precedent 
toute execution de programme inscrit dans la me - 
moire programmable. La voie d'autorisation priori - 
taire est encore ouverte tant qu'il s'agit de routines 
executes sous le contrdle de I'unite centrale. D&s 
que le compteur ordinal sera charge d'une adresse 
designant la memoire programmable, le signal de 
verrouillage/deverrouillage sera aussitdt place dans 
son etat realisant le blocage, verrouillant les regis - 
tares de Iimites et interdisant l'acc£s a la table 
repertoire. 



En pratique ceci peut avantageusement etre 
realise dans un microcircuit caracterise en ce que 
le circuit de controle d'adressage comporte une 
porte OU dite de validation, dont la sortie com- 
5 mande la transmission des signaux d'ecriture et de 
lecture de la memoire programmable, en ce qu'une 
premiere entree de cette porte de validation regoit 
un signal resultant de la comparison de toute 
adresse appeiee avec le contenu des registre de 
10 Iimites, et une autre entree par laqueile s'effectue 
I'autorisation prioritaire, regoit un signal resultant 
du produit logique entre le signal de 
verrouillage/deverrouillage et le signal de sortie 
d'un decodeur d'adresses reconnaissant les seules 
75 adresses de la zone de repertoire. 

Jusqu'a present on a consider que I'espace 
d'adressage de la memoire programmable etait 
protege dans les conditions precitees relatives a la 
zone de repertoire et la zone des applications. 
20 II peut cependant etre utile de prevoir en outre 
une certaine zone de I'espace d'adressage de la 
memoire programmable qui soit librement acces - 
sible par tout programme d'application, par exem - 
pie pour y placer provisoirement des resultats de 
25 traitement ou pour transmettre des donn6es d'une 
application a une autre. 

Sans amoindrir la securite, cette facility peut 
6tre obtenue aisement par une legfcre modification 
du circuit de controle d'adressage precedemment 
30 defini. Selon ce mode de mise en oeuvre, un 
microcircuit selon I'invention est caracterise en ce 
qu'une zone dite "publique" est en outre prevue 
dans I'espace d'adressage de la memoire pro- 
grammable, zone qui est distincte de la zone de 
35 repertoire et de la zone des applications, et en ce 
que le circuit de controle d'adressage comporte un 
decodeur d'adresse supplemental, reconnaissant 
les seules adresses de la zone publique, qui deii - 
vre en sortie un signal applique a une entree 
40 supplemental de la porte OU de validation. 

La description qui va suivre en regard des 
dessins annexes, donnes a titre d'exemples non 
limitatifs, fera bien comprendre en quoi consiste 
I'invention et comment elle peut etre realisee. 
45 La figure 1 represente un schema de principe 
d'un microcircuit selon I'invention, 
la figure 2 est un schema -bloc d'une portion 
du microcircuit deiivrant un signal de 
verrouillage/deverrouillage et, 
so la figure 3 illustre schematiquement Porganisa - 
tion d'une zone particuliere de la memoire pro- 
grammable. 

La figure 1 represente le schema general et 
simplifie d'un microcircuit selon I'invention. 
55 Sur cette figure, et pour plus de clarete, les 
elements qui ne concernent pas directement Tin - 
vention n'ont pas ete representee Le microcircuit 
comporte une unite centrale 10 de microproces- 
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seur, une memoire vive 1 1 , une memoir© a lecture 
seule 12, une memoire programmable 13 par 
exemple une EEPROM ainsi qu'un circuit de 
contrdle d'adressage 14 de la memoire program- 
mable 13. Les elements pr§cit6s sont relics entre 
eux par un systeme de bus 15 vghiculant les 
adresses et les donnees entre ces dirfeVents eie - 
ments. Pour plus simplicity le systeme de bus 15 a 
ete represents par une liaison unique bien qu'on 
puisse, selon les cas, utiliser un bus d'adresses et 
un bus de donnees qui soit s^panSs Tun de I'autre. 
Comme cela est de pratique courante, le systeme 
de bus 15 peut encore etre un bus unique sur 
lequel les adresses et les donnees sont mufti - 
plex^es temporellement. A Punite central© 10 sont 
associ^s des moyens d'acces entree - sortie 16, 
moyens qui sont iso&s du systeme de bus 15 de 
maniere a garantir un acces control par Punite 
centrale 10 aux zones sensibles du microcircuit 
contenant des donnees a proteger. 

Le circuit de contrdle d'adressage 14 regoit de 
Punite centrale 10 un ensemble de liaisons de 
commando 20 parmi lesquelles figurent essentie! - 
lement les commandos d'ecriture W de lecture R 
et d'effacement E lorsqu'elles sont destinies a la 
memoir© programmable 13. 

Les commandos de lecture et d'ecriture pour la 
memoire vive 11 et les commandes de lecture 
pour la memoire a lecture seule 12, n'ont pas 6\6 
representees, pour plus de clarte* de la figure et du 
fait qu'elles n'interferent pas avec I'invention. Les 
commandes W, R et E destinies a la memoire 
programmable 13 peuvent etre inhib^es ou vali- 
66es par le circuit de contrdle d'adressage 14 dans 
des conditions qui seront expliqu€es ci-apres. 
Conformement a une pratique en usage dans les 
microcontrdleurs, la memoire a lecture seule 12 et 
la memoire programmable 13 font partie d'un 
m§me systeme d'adressage tandis que la memoire 
vive 11 est adress^e de maniere distincte et ex- 
clusive de I'adressage des mdmoires 12 et 13. 
Dans Pespace d'adressage de la memoire pro- 
grammable 13 sont delimiters une zone de reper- 
toire ZR et une zone des applications ZA, zones 
qui sont exclusives Pune de Pautre et qui sont 
detinies une tots pour toutes par construction. 

Initialement les zones ZR et ZA sont vierges. 
Le microcircuit peut etre charge de programmes 
duplications independant les uns des autres dans 
un ordre et a des moments qui sont indifterents. 
Au fur et a mesure du chargement desdits pro- 
grammes ceux-ci vont §tre inscrits successive - 
ment dans des zones distinctes ZAt , ...ZAj, ...ZA„ 
qui sont adjacentes et qui remplissent progressi - 
vement la zone des applications ZA. 

Bien entendu, chaque zone ZA< d*une applica- 
tion determinee peut egalement contenir des don - 
nees (autres que des codes operatoires) qui sont 



propres a cette application et/ou des emplace- 
ments memoire destines a recevoir des resultats 
de traitement. Selon Pinvention la zone de reper- 
toire ZR contient une table repertoire ou les 

5 adresses de debut et de fin ainsi qu'un code de 
reference de chacun des programmes duplica- 
tions charges dans la zone des applications sont 
inscrits lors du chargement desdits programmes. 
Ainsi, un i 6me programme d'application charge dans 

10 la zone ZA< entre les adresses ZA« et ZAj h respe - 
ctivement de debut et de fin du programme d'ap- 
plication i a ete charge au cours d'un protocol© au 
cours duquel les adresses ZAn et ZAj h ont ete 
prealablement determinees et chargSes dans la 

ts table repertoire de la zone de repertoire ZR ac- 
compagnes d'un code reference du programme 
d'application i. Le protocol© de chargement qui 
vient d'etre mentionne utilise une desdites routines 
fonctionnelles inscrites de maniere immuable dans 

20 la memoire a lecture seule 12. 

Le circuit de controle d'adressage 14 est 
agence pour inhiber les commandes de lecture (R) 
d'ecriture (W) et d'effacement (E) destinees a la 
memoire programmable 13 pour des adresses qui 

25 se situent a Pexterieur de Pintervalle defini par les 
valeurs limites de debut ZAn et de fin ZA jh d'une 
application ZAj designee prealablement sur les 
accfcs d'entree/sortie 16. Pour ce faire, le systeme 
de bus 15 est partage des Pentree dans le circuit 

30 de contrdle d'adressage 14 en un bus de donnees 

21 et un bus d'adresses 22. Le bus de donnees 21 
est applique en parallel© sur deux registres ver- 
rouillables dits registres de limites 25. 26 respec- 
tivement, ou les adresses de debut et de fin d'une 

35 application en cours de traitement peuvent etre 
m£ mo risers et verrouiliees au moyen d'un signal 
de verrouillage/deverrouillage (LOC) provenant 
d'une borne 60. Le bus d'adresses 22, interne au 
circuit de controle d'adressage 14, est applique en 

40 parallel© a deux comparateurs 28, 29 respective - 
ment associes aux registres de limites 25 et 26. Le 
comparateur 28 deiivre un signal d'autorisation 
lorsque Padresse courante sur le bus d'adresses 

22 est superieure ou egale a Padresse de debut 
45 memorise© dans le registre de limites 25 tandis 

que le comparateur 29 deiivre un deuxieme signal 
d'autorisation lorsque Padresse courante sur le bus 
d'adresse 22 est inferieure ou egale a Padresse 
limite de fin d'application memorise© dans le re- 

50 gistre 26. Les deux signaux d'autorisation deiivres 
en sortie des comparateurs 28 et 29 sont appliques 
aux deux entrees d'une porte ET 30 dont la sortie 
31 present© un signal d'autorisation lorsque 
Padresse courante presentee sur le bus d'adresse 

55 22 est comprise dans les limites des adresses 
memorisees dans les registres 25 et 26. Le signal 
d'autorisation present a la sortie 31 de la porte 30 
est applique via une porte OU 32, dite de valida- 



5 



9 



EP 0 540 095 A1 



10 



tion, a Tune des entries de trois portes ET 35, 36, 
37 dont I'autre entree de chacune d'elle regoit 
respectivement les commandes de lecture (R) 
ecriture (W) et d'effacement (E). Ces commandes 
ne sont done transmises a la memoire program - 
mable 13 que lorsque les portes ET 35, 36, 37 sont 
passantes c'est-&-dire lorsque I'adresse cou- 
rante prSsente sur le bus d'adresses 22 est com - 
prise ou 6gale aux limites d'adresses m6moris6es 
dans ies registres 25 et 26 et au contraire ces 
commandes sont inhib£es dans le cas ou I'adresse 
courante est exterieure a ces valeurs limites. 

La porte OU 32 constitue une partie de ce qui 
a 6t6 appeie pr^c^demment voie d'autorisation 
prioritaire, du fait qu'elle comporte une deuxi&me 
entree 40 sur laquelle est applique un signal d'au - 
torisation durant une etape operatoire predetermi - 
n6e qui suit toute mise sous tension du microcir- 
cuit. 

Pour r£aliser ladite voie d'autorisation priori- 
taire, le signal de verrouillage/deverrouillage 
(LOC) est inverse par un inverseur 41 et applique a 
une des deux entries d'une porte ET 42. Sur 
Tautre entree de cette porte ET 42 est applique le 
signal de sortie d'un decodeur d'adresses 43 re- 
connaissant les seules adresses de la zone de 
repertoire (ZR) et fournissant a la porte ET 42 un 
signal d'autorisation lorsque I'adresse courante 
presentee sur le bus d'adresses 22 est comprise 
dans I'espace d'adressage de la zone de repertoire 
(ZR). La porte ET 42 effectue ainsi le produit 
logique entre le signal de 
verrouillage/deverrouillage (LOC) et le signal de 
sortie du decodeur d'adresses 43 pour fournir un 
signal d'autorisation prioritaire a l'entr€e 40 de la 
porte de validation 32. Le decodeur d'adresses 43 
qui reconnatt uniquement des adresses de la zone 
de repertoire (ZR) de la memoire programmable 13 
peut etre d'un type trfcs simple lorsque le nombre 
d'octets de la zone de repertoire (ZR) peut s'ex- 
primer par une puissance enti&re de deux telle 
qu'une valeur de 256 octets ou 512 octets etc. A 
titre d'exemple, la zone de repertoire peut avoir 
une adresse de debut exprimee en hexadecimal 
par la valeur 8000 et I'adresse de fin de cette zone 
par I'adresse hexadecimal© 60FF. 

Le microcircuit represent^ a la figure 1 com - 
porte encore une disposition optionnelle selon la- 
quelle une zone dite "publique" ZB est prevue 
dans I'espace d'adressage de la memoire pro- 
grammable 13, zone qui est distincte de la zone de 
repertoire ZR et de la zone des applications ZA et 
que Ton a fait figurer a titre d'exemple entre les 
zones ZR et ZA et adjacente a celles-ci. Du fait 
que Ton a pnSvu un acc£s inconditionnel a cette 
zone publique ZP, la porte de validation 32 com - 
porte une trois&me entr§e 50 par laquelle est 
applique un signal de validation provenant d'un 



decodeur d'adresses 51 stmilaire au decodeur 
d'adresses 43 a I'exception prfcs qu'il ne reconnaH 
que les seules adresses de la zone publique ZP de 
la memoire programmable 13. 

5 Ainsi que cela a d6ja ete mentionne, le signal 

de verrouillage/deverrouillage (LOC) est place dans 
un etat de deverrouillage (LOC = 0) durant une 
etape operatoire predeterminee qui suit toute mise 
sous tension du microcircuit. II peut etre g6nere 

io par tous systfemes logiques convenables permet- 
tant d'autoriser le chargement des registres de 
limites 25 et 26 et de debloquer la porte ET 42 
pour permettre la lecture et/ou recriture de la table 
repertoire situde dans la zone de repertoires ZR. 

75 Selon un mode de mise en oeuvre de I'inven - 
tion particuliferement avantageux pour la securite 
eievee qu'il procure, le signal de 
verrouillage/deverrouillage (LOC) est produit en 
liaison avec le contenu d'un compteur ordinal tel 

20 qu'il est generalement connu et associe a une 
unite centrale de microprocesseur. 

On se reporte maintenant a la figure 2 pour la 
description de cette portion du microcircuit. 

Sur cette figure, on a represente un compteur 

25 ordinal 55 qui fait partie de I'unite centrale 10 et 
qui permet I'execution pas a pas de routines 
fonctionnelles contenues dans la memoire a lecture 
seule 12. Cette disposition est par ailleurs classi- 
que dans tous les microcontroleurs ou micropro- 

30 cesseurs et ne necessite pas, de ce fait, une 
description detainee. Le compteur ordinal 55 est 
relie a un decodeur 56, 57 qui actionne a sa sortie, 
via une porte OU 66 une bascule bistable 58, par 
exemple de type RS, lorsque le contenu du 

35 compteur ordinal 55 depasse une certaine valeur 
d'adresse qui dans I'exemple illustre a pour limite 
la valeur hexadecimale 7FFF. Cette limite 
d'adresse correspond au cas ou la memoire pro - 
grammable a son adresse la plus basse exprimee 

40 en hexadecimal par la valeur 8000. Une routine 
fonction nolle, par ailleurs classique en matte re de 
microcontrdleur, effectue la remise a zero d'un 
certain nombre de registre et dans le cas precis, 
applique un signal de remise a zero de la bascule 

45 bistable 58 sur son entree de remise a zero 59. La 
bascule bistable 58 deiivre en definitive le signal 
de verrouillage/deverrouillage (LOC) sur la borne 
60 representee egalement a la figure 1, a I'entree 
du circuit de contrdle d'adressage 14. 

so A la suite d'une mise sous tension du micro - 
circuit, et tant que I'unite centrale 10 execute les 
routines fonctionnelles contenues dans la memoire 
a lecture seule 12, le compteur ordinal 55 designe 
des adresses de programme qui sont relatives a 

55 cette meme memoire a lecture seule et la bascule 
bistable 58 deiivre un signal de deverrouillage 
(LOC = 0). La table de repertoire peut etre lue ou 
ecrite sous le contrdle de I'unite centrale 10 et les 
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registres de limites 25, 26 peuvent §tre charges 
par cette m§me unite centrals. Au contraire, des 
lors qu'un programme d'application est appeie (de 
sorte que I'adresse contenue dans le compteur 
ordinal 55 depasse n£cessairement I'adresse 
hexadecimale 7FFF, donn^e comme limite dans 
Kexemple) la bascule bistable 58 est plac£e dans 
l'6tat oppose au premier etat et deiivre un signal 
de verrouillage sur la borne 60 (LOC = 1). Les 
registres de limites 25 et 26 ainsi que la vole 
d'autorisation prioritaire seront ddsormais verrouil - 
i£s jusqu'a la prochaine mise hors tension du mi - 
crocircuit Comme on le volt cette disposition offre 
toute security pour garantir une absence d'interf6 - 
rence entre les differents programmes d'applica- 
tions susceptibles d'etre charges dans la zone des 
applications ZA. 

La porte OU 66 permet egalement une variante 
de fonctionnement selon laquelle le signal de ver- 
rouillage (LOC = 1) peut etre produit par une 
routine spScifique contenue dans la m6moire ROM 
12, et done meme si le contenu du compteur n'a 
pas encore d6pass6 la valeur limite de 7FFF. La 
routine fonctionnelle prevue a cet effet impose a 
I'unite centrale 10 d'emettre un signal de com- 
mando sur une liaison 67 qui est appliquee a une 
deuxieme entree de la porte OU 66. On peut done 
ainsi Smettre un signal de verrouillage par pro- 
grammation qui subsistera jusqu'a la prochaine 
remise a zero. Cette disposition permet d'accroltre 
encore la securite pendant le chargement d'un 
nouveau programme d'application et pendant 
I'ex^cution d'une application qui ne ferait appel 
qu'a des routines contenues dans la mgmoire ROM 
12 et dont la zone ZA| reserv^e dans la memoire 
programmable ne contiendrait que des donnSes (et 
aucun code operatoire). 

A I'aide de la figure 3, on va expliquer succin - 
tement comment la zone de repertoire ZR de la 
memoire programmable 13 peut etre organise. La 
figure 3 se r&ere par ailteurs a un exemple dont 
les valeurs sont purement arbitraires et n'ont pas 
d'autre but que de rendre les explications plus 
claires. 

On suppose que la zone repertoire de la me - 
moire programmable 13 commence a I'adresse 
hexadecimale 8000 et finit a I'adresse 80FF. Dans 
cette zone d'un volume de 256 octets, on peut 
prgvoir, si on le desire, une portion designee par 
ZID destin€e a recevoir des donnees d'identifica - 
tion de la carte, du proprietaire de ceile - ci et des 
ci£s. En dehors de la zone d'identification ZID se 
situe la table de repertoire TR proprement dite qui 
debute a I'adresse INI et s'etend jusqu'a i'adresse 
hexadecimale 80FF. Comme indique sur la figure, 
la table repertoire TR contient les inscriptions 
successives d'un premier programme charge, dont 
le code de reference est appeie "PR-APP- A", 



d'une longueur de 350 octets, dont I'adresse 
hexadecimale de debut d'execution de programme 
est egale a 8200 ainsi que I'adresse de debut de 
zone, et I'adresse de fin de zone egale a 835D, 

5 puis un programme reference "PR-APP-B" 
d'une longueur de 250 octets, ayant pour adresse 
de debut d'execution de programme ia valeur 
hexadecimale 8365, pour I'adresse de debut de 
zone, 835E pour I'adresse de fin 8457, et enfin un 

to programme reference "PR-APP-C", d'une lon- 
gueur de 180 octets, ayant pour adresse de debut 
d'execution de programme la valeur hexadecimale 
8460 pour I'adresse de debut de zone, 8458 et 
pour adresse de fin la valeur 850C. En effet, les 

75 adresses de debut d'execution de programme, 
comme I'indique cet exemple, ne coincident pas 
necessairement avec i'adresse de debut de zone 
allouee au meme programme, mais elles sont ne - 
cessairement comprises dans ladite zone allouee. 

20 On va decrire tout d'abord le cas oO un pro- 
gramme d'application d£ja charge dans la carte est 
appeie sur les moyens d'acces d'entree/sortie. 

Toute demande d'execution d'un programme 
d'application fait I'objet d'une procedure qui peut 

25 se decomposer en 5 etapes principales : 

- une etape d'initiaNsation qui peut inclure une 
procedure d'identification de la carte et son 
utilisateur, 

- une procedure de demande de I'application 
30 annoncee sur les moyens d'entree - sortie, 

- une procedure de recherche dans la table de 
repertoire TR pour determiner si ('application 
demandee existe, et dans ('affirmative, le 
chargement des donnees specifiques de 

35 I'application preievees dans cette table, 

- le chargement des registres de limites, 

- et enfin I'execution proprement dite du pro- 
gramme d'application demande. 

Des la mise sous tension du microcircuit, la bas - 

40 cule bistable 58 est remise a zero en meme temps 
qu'un certain nombre de registres et notamment le 
compteur ordinal 55. Apres un eventuel protocole 
de reconnaissance mettant en jeu des donnees 
d'identification contenues dans la portion d'identi - 

45 fication ZID de la zone repertoire ZR, un pro- 
gramme d'application par exemple celui reference 
"PR-APP-B" est appeie. 
Sous I'effet d'une routine preetablie, I'unite centrale 
10 effectue une recherche dans la table repertoire 

so TR de maniere a determiner si un tel programme 
d'application est present. Dans I'affirmative les va - 
leurs d'adresse de debut et de fin de ce program - 
me d'application, dans I'exemple les adresses 
hexadecimales 835E et 8457 respectivement, sont 

55 preievees dans la table de repertoire TR et toujours 
sous I'effet d'une routine preetablie ces valeurs 
limites sont charges dans les registres des limites 
25 et 26 respectivement. Jusqu'a present le fonc - 
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tionnement du microcircuit n'a fait appel qu'a des 
routines situSes dans la mSmoire a lecture seule 
12 de sorte que le compteur ordinal n'a jamais 
franchi la limite des adresses d£signant la memoire 
programmable 13 soit dans notre exemple una 
adresse supSrieure a la valeur hexadecimale 7FFF. 
Dans I'etape op^ratoire qui suit et qui consiste a 
executor le programme appeie, le compteur ordinal 
55 est charge* avec I'adresse de debut d'ex^cution 
du programme duplication appeie, par exemple 
I'adresse hexad^ciame 8365. Ceci entraTne un 
changement d'etat de la bascule bistable 58 et 
procure sur la borne 60 un signal de verrouillage 
(LOC = 1). Ce signal a pour effet de verrouiller les 
registres de limites 25 et 26 et de bloquer la voie 
d'autorisation prioritaire form^e par la branche 
comportant Pinverseur 41, la porte ET 42 et Pen- 
tose 40 de la porte de validation 32. D6sormais les 
operations d'ecriture, de lecture et d'effacement de 
la memoire programmable ne peuvent plus etre 
executees que dans la seule portion comprise dans 
les limites de debut et de fin du programme appeie 
ou dans la zone publique ZP. Cet acc&s s£lectif va 
persister jusqu'a la mise hors tension du microcir- 
cuit. Les operations d'^criture et de lecture dans la 
zone dite publique ZP restent possibles au moyen 
du signal d'autorisation present sur I ( entr6e 50 de 
la porte de validation 32 et provenant du d£codeur 
d'adresse 51 qui reconnalt les adresses corres- 
pondant a cette zone ZP. 

On en vient maintenant a dScrire le fonction - 
nement du microcircuit dans le cas ou un pro- 
gramme d'application doit §tre charge dans la 
memoire programmable 13. D6s la mise sous ten- 
sion du microcircuit, une etape d'initialisation est 
engag^e qui est essentiellement simiiaire a celle 
d6ja mentionn^e pour l v ex6cution d'un programme 
d'application. Dans une seconde etape, et sous le 
controle d'une routine fonctionnetle preetablie, le 
code de reference du programme a charger est 
annonce sur les entrees - sorties ainsi que le vo- 
lume de memoire n^cessaire a ce programme ex - 
prirn^ par exemple en nombre d'octets. Dans une 
troisieme etape operatoire, et egalement sous I'ef- 
fet d'une routine fonctionnelle preetablie, une re- 
cherche est effective dans la table repertoire TR 
contenue dans la zone de repertoire ZR de ma- 
nure a determiner si le programme demand^ a 
deja ete charge et sinon quelle est la derniere 
adresse limite de fin de programme inscrite dans la 
table. Cette adresse correspond egalement a 
I'adresse occupee la plus eievee de la zone ZA 
puisque les programmes ont 6te charges succes - 
sivement a des adresses croissantes. Dans 
I'exemple il s'agit de la valeur hexadecimale 850C. 
La m§me routine fonctionnelle determine d'une 
part la valeur d'adresse qui suit immediatement 
c'est-a-dire I'adresse hexadecimale 850D qui 



sera prevue comma valeur limite de d£but du 
nouveau programme a charger et calcule d'autre 
part quelle sera I'adresse de fin de programme a 
charger compte tenu du volume de memoire an - 

5 nonce dans la seconde etape. Dans une quatrieme 
etape, I'unite centrale effectue un test pour deter- 
miner si I'adresse de fin de programme ainsi cal - 
cuiee est compatible avec I'adresse la plus eievee 
de la zone des applications ZA, puis sous I'effet 

io d'une routine preetablie, les valeurs limites de de - 
but et de fin de programme ainsi determinees sont 
chargees dans les registres de limites 25 et 26. Du 
fait que jusqu'a present I'unite centrale a effectue 
des routines fonctionnelles situees dans la m6- 

75 moire a lecture seule 12, le compteur ordinal n'a 
jamais franchi la limite des valeurs d'adresse qui 
concernent la memoire programmable 13. Ainsi le 
signal de verrouillage/deverrouillage est dans son 
etat de deverrouillage (LOC = 0) ce qui a permis 

20 le chargement des registres des limites 25 et 26 
ainsi que la lecture de la table de repertoire au 
moyen de la voie d'autorisation prioritaire 41, 42 et 
32. Dans une cinquieme etape et sous I'effet d'une 
routine fonctionnelle, I'unite centrale 10 complete la 

25 table repertoire de la zone de repertoire ZR en 
inscrivant a la suite des references d£ja presentes, 
le code de reference, les valeurs limites d'adresses 
de debut et de fin precedemment determinees et 
qui concernent le programme d'application en voie 

30 de chargement, ainsi que I'adresse de debut 
d'execution de ce programme. 

Une sixieme etape operatoire, qui suit, 
concerne essentiellement le chargement dudit 
programme, chargement qui ne peut etre accompli 

35 qu'a I'interieur des limites fix£es par les valeurs 
d'adresses de debut et de fin memorises dans les 
registres des limites 25 et 26. Pendant ce charge - 
ment les registres de limites 25 et 26 peuvent ne 
pas §tre verrouilies (LOC = 0) mais lesdits regis - 

40 tres effectuent le controle des operations d*ecriture 
de la mSme maniere que s'iis avaient ete verrouil - 
ies. La securite est neanmoins maintenue du fait 
que le chargement est execute sous le controle de 
I'unite centrale 10 par I'effet d'une routine fonc- 

45 tionnelle qui ne peut §tre modifiee par un utilisa- 
teur. Toutefois, il est egalement possible d'activer 
la bascule 58 par programmation au moyen d'un 
signal transmis par la liaison 67 a la porte OU 66. 
Dans ce cas les registres de limites peuvent etre 

50 verrouilies lors du chargement. Toute tentative de 
chargement d'un programme d'application d'une 
longueur superieure au volume de memoire an- 
nonce restera inefficace par I'effet du controle 
exerce par les registres de limites 25 et 26 et de la 

55 porte ET 30. 

Si on le desire retape de chargement du pro- 
gramme peut etre suivie par une verification des 
donnees chargees, une verification de signature 
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finale, un test de parite\ at... II est aise* de d&ecter 
una tentative de chargement d'un programme de 
longueur supeVieure h la longueur annonc£e du fait 
que la ou les demieres donn^es presentees au 
chargement ne sont pas en fait en registries dans 5 
la memoire programmable de sorte qu'une verifi- 
cation de ces donn£es finales rivele la tentative 
d'un chargement abusif qu'il soit accidentel ou 
frauduleux. 

En se r£f£rant a nouveau a la figure 1, un w 
dispositif additionnel pour la signalisation d'une 
anomalie de fonctionnement va maintenant etre 
d£crtt. Ce dispositif additionnel comporte une porte 
ET 62 a deux entries, une porte OU 63 h 3 
entries et un inverseur 64. 15 

L'inverseur 64 regoit en entree le signal de 
sortie de la porte de validation 32, et le transmet 
apres inversion, & une entree de la porte ET 62. 

La porte OU 63 a sa sortie connected & I'autre 
entree de la porte ET 62 et regoit en entree les 20 
trois signaux de commando R, W, E destines & la 
memoire programmable 13, en formant ainsi la 
somme logique de ces signaux de commando. 

Lorsque Tune de ces operations est demanded, 
le signal en sortie de la porte OU 63 est a retat 25 
haut. Simultaniment, si aucune des conditions 
d'autorisation n'est rialisie, ce qui produit un si- 
gnal a I'etat bas en sortie de la porte OU 32, la 
porte ET 62 est alors activie et produit en sortie 
un signal renvoye* a I'unite centrale 10, par exem- 30 
pie un signal d'interruption (INT = 1 ). 

Ainsi, dans le cas d'utilisation d'une interrup - 
tion, une anomalie de fonctionnement et plus par- 
ticulierement une demande non autorisie d'acces 
a la memoire programmable 13 aboutira a une 35 
interruption de fonctionnement du microcircuit 
(interruption non masquable) et on peut, si on le 
desire, produire un message d'avertissement sur le 
terminal d'exploitation de la carte. 

Le signal INT qui est produit en cas d'anomalie 40 
peut §tre utilise pour opirer toute modification 
disirable du fonctionnement du microcircuit : par 
exemple invalider le programme qui a produit 
I'anomalie, voire invalider totalement le fonction- 
nement de la carte. 45 

Une consequence avantageuse de invention 
est que seules les routines fonctionnelles incrites 
dans la memoire h lecture seule devront §tre ex- 
tensivement testies et approuvees alors que les 
programmes duplications pourront §tre crees par so 
diverses entitis, sous leur propre responsabilite, et 
sans risque d'interterence indue entre les applica- 
tions. 

Le microcircuit selon I'invention offre done une 
parfaite securite pour une utilisation de carte & 55 
puce multi- applications. 



Revendications 

1. Microcircuit pour carte a puce comprenant 
entre -autres : des moyens d'acces entree - 
sortie, au moins une memoire qui est pro- 
grammable et accessible par un espace 
d'adressage h adresses consecutives, un cir- 
cuit de contrdle d'adressage de cette memoire 
programmable determinant soit une inhibition, 
soit une validation des commandes d'ecriture 
et/ou de lecture par la comparison de 
Tadresse demandee avec deux valeurs limites 
de debut et de fin d'une zone particuliere 
d'adresses, limites qui sont memorisies au 
sein du circuit de contrdle d'adressage lequel 
circuit comporte egalement une voie d'autori - 
sation prioritaire permettant de s'affranchir 
temporairement de ladite inhibition dans des 
circonstances predetermines et particulieres, 
caracterise en ce que, en vue d'un chargement 
et d'une exploitation de programmes d'appli - 
cations indipendants les uns des autres, le 
microcircuit est muni d'une unite centrale de 
microprocessor, d'une memoire h lecture 
seule (ROM) contenant notamment des routi - 
nes fonctionnelles exclusivement exicutables 
par I'unite centrale et sous sa dependance, en 
ce que dans I'espace d'adressage de la me - 
moire programmable sont deiimitees une zone 
dite de repertoire et une zone dite des appli - 
cations, lesquelies zones sont exclusives I'une 
de I'autre, en ce que la zone de repertoire 
contient une table repertoire ou les adresses 
de debut et de fin ainsi qu'un code de refe- 
rence de chacun des programmes duplica- 
tions susceptible d'etre charge dans une por- 
tion de la zone des applications, sont inscrits 
au fur et a mesure du chargement desdits 
programmes et en utiltsant une desdites rou - 
tines fonctionnelles, en ce que le circuit de 
contrdle d'adressage est agence pour inhiber 
les commandes d'ecriture et de lecture de la 
memoire programmable pour des adresses qui 
se situent & I'exterieur de I'intervalle difini par 
les valeurs limites de debut et de fin d'une 
application designee prialablement sur les 
acces d'entree- sortie, limites qui sont me- 
morises dans des registres verrouillables, 
appeies registres de limites, tandis que la voie 
dite d'autorisation prioritaire comporte des 
moyens pour s'affranchir de Inhibition prici - 
tee en autorisant recriture et la lecture de la 
zone de repertoire & la condition exclusive que 
ces operations soient effectuees au moyen 
d'une desdites routines fonctionnelles durant 
une etape operatoire predeterminee durant 
laquelle les registres contenant les valeurs li - 
mites sont deverrouilies. 
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2. Microcircuit selon la revendication 1 , caracte - 
rise en ce qu'il comporte une bascule bistable, 
placde dans un premier etat exctusivement lors 
d'une mise sous tension du microcircuit, puis 
plac£e dans un deux&me etat oppose au 
premier cfes qu'un compteur ordinal associe a 
I'unite centrale, contient une valeur d'adresse 
comprise dans I'espace d'adressage de la 
memoire programmable, et en ce que cette 
bascule bistable deiivre un signal de, 
verrouillage/d6verrouillage pour la commande 
de verrouillage des registres de limites et pour 
la commande de la voie d'autorisation priori - 
taire. 

3. Microcircuit selon la revendication 2, caracte - 
rise en ce que lad'rte bascule bistable peut 
egalement etre plac^e dans (edit deuxifcme 
etat par un signal de commande deiivre par 
I'unitd centrale sous I'effet d'une routine fonc - 
tionnelle pr6vue a cet effet. 



lecture, d'ecriture et d'effacement, a la sortie 
d'une porte OU additionneile. 
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4. Microcircuit selon Tune des revendication s 1 a 
3, caracterise en ce que le circuit de controie 
d'adressage comporte une porte OU dite de 25 
validation, dont la sortie commande la tran- 
smission des signaux d'ecriture et de lecture 
de la memoire programmable, en ce qu'une 
premifere entree de cette porte de validation 
regoit un signal resultant de la comparaison de 30 
toute adresse appelSe avec le contenu des 
registres de limites, et une autre entree par 
laquelle s'effectue I'autorisation prioritaire, re- 
goit un signal resultant du produit logique entre 
le signal de verrouillage/d6verrouil!age et le 35 
signal de sortie d'un d£codeur d'adresses re - 
connaissant les seules adresses de la zone de 
repertoire. 



5. Microcircuit selon la revendication 4, caracte - 40 
rise en ce qu'une zone dite "publique" est en 
outre prgvue dans I'espace d'adressage de la 
memoire programmable, zone qui est distincte 
de la zone de repertoire et de la zone des 
application, et en ce que le circuit de contrdle 45 
d'adressage comporte un dgcodeur d'adresse 
supplemental reconnaissant les seules 
adresses de la zone publique, qui deiivre en 
sortie un signal applique a une entree sup- 
plemental de la porte OU de validation. 50 



6. Microcircuit selon I'une des revendications 4 
ou 5, caracterise en ce qu'un signal de de - 
tection d'anomalie (INT) est produit en sortie 
d'une porte ET additionnelle dont une pre- 55 
mi&re entree regoit le signal issu de la porte 
de validation, et une deuxidme entree regoit la 
somme logique des signaux de commande de 
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